<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<ui:composition template="/templates/templateListar.xhtml"
	xmlns="http://www.w3.org/1999/xhtml"
	xmlns:h="http://java.sun.com/jsf/html"
	xmlns:f="http://java.sun.com/jsf/core"
	xmlns:ui="http://java.sun.com/jsf/facelets"
	xmlns:p="http://primefaces.org/ui"
	xmlns:fn="http://java.sun.com/jsp/jstl/functions">

	<ui:define name="conteudo">
		<ui:param name="actionBean" value="#{agendamentoMB}" />
		<h:form id="frm">

			<p:hotkey bind="esc"
				handler="document.getElementById('frmTab:btnCancelar').click()" />

		</h:form>

		<h:form id="frmTab">
			<h:panelGrid columns="4" id="filtro">
				<p:outputLabel value="Status:" for="st" />
				<p:selectOneMenu id="st" filterMatchMode="contains" filter="true"
					value="#{agendamentoMB.status}" style="width:250px;">
					
					<f:selectItems value="#{agendamentoMB.listaStatusAgendamentoBusca}"
						var="status" itemLabel="#{status.descricao}" itemValue="#{status}"></f:selectItems>

				</p:selectOneMenu>
				<p:outputLabel value="Data Marcada:"></p:outputLabel>
				<p:inputMask value="#{agendamentoMB.dataBusca}" mask="99/99/9999">
					<f:convertDateTime pattern="dd/MM/yyyy" timeZone="GMT-3"></f:convertDateTime>
				</p:inputMask>
				<p:commandButton actionListener="#{agendamentoMB.buscar}" value="Buscar"
					update="tabela">
				</p:commandButton>
				<p:commandButton actionListener="#{agendamentoMB.limparBusca}" value="Limpar"
					update="filtro,tabela">
				</p:commandButton>
			</h:panelGrid>
			<p:commandButton id="btnCancelar" action="#{agendamentoMB.sair}"
				style="display:none" immediate="true" value="cancelar" />
			<p:commandButton actionListener="#{agendamentoMB.abrirModalIncluir}"
				 update=":dialogCadastro,:frmDialogAgendamento"
				value="Novo Registro" style="float:left" icon="ui-icon-disk"
				ajax="true" oncomplete="dialogCadastroAgendamento.show()">
				<f:param name="modooperacao" value="INCLUIR" />
			</p:commandButton>
			<p:dataTable id="tabela" var="item" value="#{agendamentoMB.lista}"
				paginator="true" rows="10" emptyMessage="Não há registros"
				paginatorTemplate="{CurrentPageReport}  {FirstPageLink} {PreviousPageLink} {PageLinks} {NextPageLink} {LastPageLink} {RowsPerPageDropdown}"
				currentPageReportTemplate="(Página: {currentPage}/{totalPages})"
				rowsPerPageTemplate="10,15,25,50,100" paginatorPosition="bottom"
				sortOrder="ascendind" sortBy="#{item.dataMarcada}"  selectionMode="single" rowKey="#{item.codigo}">
				<f:facet name="header">Agendamentos
				</f:facet>
				<p:column headerText="Ficha" sortBy="#{item.codigo}">
					<h:outputText value="#{item.codigo}" />
				</p:column>

				<p:column headerText="Veterinário"
					filterBy="#{item.funcionario.dadosCadastro.nome}"
					filterMatchMode="contains"
					sortBy="#{item.funcionario.dadosCadastro.nome}">
					<h:outputText
						value="#{item.funcionario.matricula} - #{item.funcionario.dadosCadastro.nome}" />
				</p:column>

				<p:column headerText="Cliente"
					filterBy="#{item.cliente.dadosCadastro.nome}"
					filterMatchMode="contains"
					sortBy="#{item.cliente.dadosCadastro.nome}">

					<h:outputText value="#{item.cliente.dadosCadastro.nome}" />

				</p:column>
				<p:column headerText="Animal" filterBy="#{item.animal.nomeAnimal}"
					filterMatchMode="contains" sortBy="#{item.animal.nomeAnimal}">

					<h:outputText value="#{item.animal.nomeAnimal}" />

				</p:column>

				<p:column headerText="Data Marcada" sortBy="#{item.dataMarcada}">

					<h:outputText value="#{item.dataMarcada}">
						<f:convertDateTime pattern="dd/MM/yyyy" timeZone="GMT-3" />
					</h:outputText>

				</p:column>

				<p:column headerText="Hora Marcada" sortBy="#{item.horaMarcada}}">

					<h:outputText value="#{item.horaMarcada}" converter="horaConverter" />

				</p:column>

				<p:column headerText="Tipo"
					sortBy="#{item.tipoAgendamento.descricao}">

					<h:outputText value="#{item.tipoAgendamento.descricao}" />

				</p:column>


				<p:column headerText="Ações" style="text-align:center">

					<p:commandButton title="Alterar" icon="ui-icon-pencil"
						styleClass="styleBotao"
						actionListener="#{agendamentoMB.abrirModal(item)}"
						update=":frmDialogAgendamento,:mensagem">
						<f:param name="modooperacao" value="ALTERAR" />
					</p:commandButton>

					<p:commandButton actionListener="#{agendamentoMB.abrirModal(item)}"
						styleClass="styleBotao" title="Consultar"
						update=":frmDialogAgendamento" ajax="true"
						oncomplete="dialogCadastroAgendamento.show()"
						icon="ui-icon-search">

						<f:param name="modooperacao" value="CONSULTAR" />
					</p:commandButton>

					<p:commandButton title="Excluir" update=":Excluir"
						oncomplete="confirmation.show()" styleClass="styleRed"
						icon="ui-icon-close">
						<f:setPropertyActionListener
							target="#{agendamentoMB.agendamentoSelecionado}"
							value="#{item.clone()}" />
					</p:commandButton>

					<p:commandButton title="Enviar e-mail" ajax="false"
						styleClass="styleBotao" icon="ui-icon-circle-check"
						action="#{agendamentoMB.enviarEmail(item)}">
						<p:tooltip value="Clique para enviar E-mail para o Cliente"></p:tooltip>
					</p:commandButton>

					<p:commandButton title="Imprimir" ajax="false" 
						styleClass="styleBotao" icon="ui-icon-print"
						action="#{agendamentoMB.imprimir(item)}">
						<p:tooltip value="Clique para imprimir agendamento do Cliente"></p:tooltip>
					</p:commandButton>

				</p:column>

				<f:facet name="footer">
					<p:outputLabel value="Total de " />
					<p:outputLabel
						value="#{fn:length(agendamentoMB.lista)} registro(s)" />

				</f:facet>

			</p:dataTable>


		</h:form>

		<ui:include src="dialogCadastroAgendamento.xhtml" />
		<ui:include src="/includes/confirmacaoExcluir.xhtml" />
	</ui:define>
</ui:composition>

